/*===============================================================================
************   Sortable   ************
===============================================================================*/
+function ($) {
    "use strict";

    $.sortableToggle = function (sortableContainer) {
        sortableContainer = $(sortableContainer);
        if (sortableContainer.length === 0) sortableContainer = $('.list-block.sortable');
        sortableContainer.toggleClass('sortable-opened');
        if (sortableContainer.hasClass('sortable-opened')) {
            sortableContainer.trigger('open');
        }
        else {
            sortableContainer.trigger('close');
        }
        return sortableContainer;
    };
    $.sortableOpen = function (sortableContainer) {
        sortableContainer = $(sortableContainer);
        if (sortableContainer.length === 0) sortableContainer = $('.list-block.sortable');
        sortableContainer.addClass('sortable-opened');
        sortableContainer.trigger('open');
        return sortableContainer;
    };
    $.sortableClose = function (sortableContainer) {
        sortableContainer = $(sortableContainer);
        if (sortableContainer.length === 0) sortableContainer = $('.list-block.sortable');
        sortableContainer.removeClass('sortable-opened');
        sortableContainer.trigger('close');
        return sortableContainer;
    };
    $.initSortable = function () {
        var isTouched, isMoved, touchStartY, touchesDiff, sortingEl, sortingElHeight, sortingItems, minTop, maxTop, insertAfter, insertBefore, sortableContainer;

        function handleTouchStart(e) {
            isMoved = false;
            isTouched = true;
            touchStartY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;
            /*jshint validthis:true */
            sortingEl = $(this).parent();
            sortingItems = sortingEl.parent().find('li');
            sortableContainer = sortingEl.parents('.sortable');
            e.preventDefault();
            $.allowPanelOpen = $.allowSwipeout = false;
        }
        function handleTouchMove(e) {
            if (!isTouched || !sortingEl) return;
            //var pageX = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;
            var pageY = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;
            if (!isMoved) {
                sortingEl.addClass('sorting');
                sortableContainer.addClass('sortable-sorting');
                minTop = sortingEl[0].offsetTop;
                maxTop = sortingEl.parent().height() - sortingEl[0].offsetTop - sortingEl.height();
                sortingElHeight = sortingEl[0].offsetHeight;
            }
            isMoved = true;

            e.preventDefault();
            e.f7PreventPanelSwipe = true;
            touchesDiff = pageY - touchStartY;
            var translate = touchesDiff;
            if (translate < -minTop) translate = -minTop;
            if (translate > maxTop) translate = maxTop;
            sortingEl.transform('translate3d(0,' + translate + 'px,0)');

            insertBefore = insertAfter = undefined;

            sortingItems.each(function () {
                var currentEl = $(this);
                if (currentEl[0] === sortingEl[0]) return;
                var currentElOffset = currentEl[0].offsetTop;
                var currentElHeight = currentEl.height();
                var sortingElOffset = sortingEl[0].offsetTop + translate;

                if ((sortingElOffset >= currentElOffset - currentElHeight / 2) && sortingEl.index() < currentEl.index()) {
                    currentEl.transform('translate3d(0, '+(-sortingElHeight)+'px,0)');
                    insertAfter = currentEl;
                    insertBefore = undefined;
                }
                else if ((sortingElOffset <= currentElOffset + currentElHeight / 2) && sortingEl.index() > currentEl.index()) {
                    currentEl.transform('translate3d(0, '+(sortingElHeight)+'px,0)');
                    insertAfter = undefined;
                    if (!insertBefore) insertBefore = currentEl;
                }
                else {
                    $(this).transform('translate3d(0, 0%,0)');
                }
            });
        }
        function handleTouchEnd(e) {
            $.allowPanelOpen = $.allowSwipeout = true;
            if (!isTouched || !isMoved) {
                isTouched = false;
                isMoved = false;
                return;
            }
            e.preventDefault();
            sortingItems.transform('');
            sortingEl.removeClass('sorting');
            sortableContainer.removeClass('sortable-sorting');
            var virtualList, oldIndex, newIndex;
            if (insertAfter) {
                sortingEl.insertAfter(insertAfter);
                sortingEl.trigger('sort');
            }
            if (insertBefore) {
                sortingEl.insertBefore(insertBefore);
                sortingEl.trigger('sort');
            }
            if ((insertAfter || insertBefore) && sortableContainer.hasClass('virtual-list')) {
                virtualList = sortableContainer[0].f7VirtualList;
                oldIndex = sortingEl[0].f7VirtualListIndex;
                newIndex = insertBefore ? insertBefore[0].f7VirtualListIndex : insertAfter[0].f7VirtualListIndex;
                if (virtualList) virtualList.moveItem(oldIndex, newIndex);
            }
            insertAfter = insertBefore = undefined;
            isTouched = false;
            isMoved = false;
        }
        $(document).on($.touchEvents.start, '.list-block.sortable .sortable-handler', handleTouchStart);
        if ($.support.touch) {
            $(document).on($.touchEvents.move, '.list-block.sortable .sortable-handler', handleTouchMove);
            $(document).on($.touchEvents.end, '.list-block.sortable .sortable-handler', handleTouchEnd);
        }
        else {
            $(document).on($.touchEvents.move, handleTouchMove);
            $(document).on($.touchEvents.end, handleTouchEnd);
        }

    };

    $(document).on("click", ".toggle-sortable, .open-sortable, .close-sortable", function(e) {
        e.preventDefault();
        var clicked = $(this);
        // Collect Clicked data- attributes
        var clickedData = clicked.dataset();
        // Sortable
        if (clicked.hasClass('toggle-sortable')) {
            $.sortableToggle(clickedData.sortable);
        }
        if (clicked.hasClass('open-sortable')) {
            $.sortableOpen(clickedData.sortable);
        }
        if (clicked.hasClass('close-sortable')) {
            $.sortableClose(clickedData.sortable);
        }
    });

}(Zepto);
